草庐IT

c++ - 制作不同子类实例的 vector

全部标签

c - Ruby C 扩展 API 问题

所以,最近我不幸地需要为Ruby做一个C扩展(因为性能)。因为我在理解上有问题VALUE(并且仍然如此),所以我查看了Ruby源代码并发现:typedefunsignedlongVALUE;(LinktoSource,但您会注意到它还有其他一些“方法”,但我认为它本质上是一个long;如果我错了,请纠正我)。因此,在进一步调查时,我发现了一个有趣的blogpost,其中说:"...insomecasestheVALUEobjectcouldBEthedatainsteadofPOINTINGTOthedata."令我困惑的是,当我尝试从Ruby将字符串传递给C并使用RSTRING_PT

c - 在 C 中扩展 ruby​​ - 如何指定函数的默认参数值?

我正在尝试为将生成一个类的ruby​​编写C扩展。我正在研究如何为类定义一些默认参数。例如,如果我在ruby​​中有这个类decleration:classMyClassdefinitialize(name,age=10)@name=name@age=ageendend您可以使用mc=MyClass.new("blah")初始化它,年龄参数将在内部设置。我如何在C中执行此操作?到目前为止我得到了这个,但这迫使进入另一个论点:require"ruby.h"staticVALUEmy_init(VALUEself,VALUEname,VALUEage){rb_iv_set(self,"@n

Ruby 方法如 `self` 引用实例

Ruby中是否有一种方法引用类的当前实例,就像self引用类本身一样? 最佳答案 self总是指一个实例,但是一个类本身就是Class的一个实例。在某些上下文中,self将引用这样的实例。classHello#Weareinsidethebodyoftheclass,so`self`#referstothecurrentinstanceof`Class`pselfdeffoo#Weareinsideaninstancemethod,so`self`#referstothecurrentinstanceof`Hello`returns

c - 如何在 Mac OS X 上使用 ulimit 或每个进程为 C 或 Ruby 程序更改堆栈大小?

似乎为C程序或Ruby程序(使用C堆栈)设置堆栈大小的推荐方法是使用ulimit。在Bash外壳中。但是$ulimit-s8192$ulimit-s16384-bash:ulimit:stacksize:cannotmodifylimit:Operationnotpermitted和sudo也没有帮助。有没有办法将其设置为16MB、32MB或64MB?我认为应该有一种方法可以在每次程序调用时设置它,而不是同时设置系统范围的参数?现在8192可能意味着8MB,如果与一个进程可以使用的内存量相比,这是非常小的,有时最多2GB的RAM。(更新注释:ulimit-a可以显示其当前值)。(更新2

ruby - 使用 Ruby 和 Minitest,如何运行具有不同数据的相同测试用例,仅由列表控制

我有对电话号码进行操作的Ruby2.0代码,我想使用MiniTest对其进行测试。我有一个函数,它接受一个电话号码参数并对其进行测试(包括断言)。每次调用该函数时,我都希望它成为一个新的测试用例。像这样:listOfPhoneNumbersForTesting.each{|phone|testphonephone}我不想要的是:classtest2125551212...重复10、20或100次以测试每个电话号码...显然,我可以将循环代码放在MiniTest::Unit::TestCase中,但无论我测试多少个电话号码,这都会导致只有一个测试用例,我不喜欢这样。(此外,如果其中一个断

ruby-on-rails - 具有不同 HTTP 请求类型的两个路由如何共享相同的名称?

在Rails3.2中,我使用这些路由声明:get'contact'=>'contact#new',:as=>'contact'post'contact'=>'contact#create',:as=>'contact'它们导致(rakeroutes):contact_enGET/en/contact(.:format)contact#new{:locale=>"en"}contact_deGET/de/kontakt(.:format)contact#new{:locale=>"de"}contact_enPOST/en/contact(.:format)contact#create{

ruby - 创建一个根据角色执行不同任务的 Capistrano 任务

我正在寻找一种方法来调用单个Capistrano任务来为不同的角色执行不同的事情。Capistrano是否能够做到这一点,或者我是否为每个角色编写了特定任务? 最佳答案 在Capistrano中执行此操作的标准方法:task:whatever,:roles=>[:x,:y,:z]dox_tasksy_tasksz_tasksendtask:x_tasks,:roles=>:xdo#...endtask:y_tasks,:roles=>:ydo#...endtask:z_tasks,:roles=>:zdo#...end所以是的,您确

ruby-on-rails - 从父类(super class)调用子类方法

前言:这是在Rails应用程序的上下文中。然而,这个问题是特定于Ruby的。假设我有一个Media对象。classMedia我在几个子类中扩展了它:classImage在Media类中,我想从适当的子类中调用show的实现。因此,对于Media,如果self是一个Video,那么它将调用Video的show方法。如果self是Image,它将调用Image的show方法。我有Java背景,首先想到的是“在父类(superclass)中创建一个抽象方法”。但是,我在多个地方(包括StackOverflow)读到抽象方法并不是在Ruby中处理此问题的最佳方式。考虑到这一点,我开始了rese

ruby - Ruby中具有相同名称和不同参数的方法(方法重载)

我有这个代码:defsetVelocity(x,y,yaw)setVelocity(Command2d.new(x,y,yaw))enddefsetVelocity(vel)......endvel是一个Command2D类,它有3个属性,是Comparable并定义了+,基本上是一个方便我管理这3个属性的类,所以我想在我的库内部使用它(不想让它们私有(private),要么给他们起奇怪的名字)。但是即使参数数量不同,Ruby似乎也只保留最后一个setVelocity。所以当我用3个参数调用setVelocity时,会说我只需要用一个参数调用该方法。 最佳答

ruby-on-rails - 如何配置额外的/不同的迁移文件夹

我和一位同事在共享某些模型的不同项目中工作。因此,我们通过git子模块共享模型。此外,我们还希望能够共享迁移:这样,我同事的迁移将在我项目的文件夹db/migrate/other_db中。如何配置Rails迁移以在这个额外的文件夹中运行迁移? 最佳答案 在您的配置文件中(config/application.rb用于所有环境或config/environments/$(environment).rb仅用于特定环境)添加此行:config.paths['db/migrate']+='db/migrate/other_db'如果你想改变